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Amendiwents to the Claims; 

1 (ctwrently amended): A computerized system coicprising; 
a processing unit; 

a system memory coupled to the processing unit through a system bus; 
a computer-readable medium coupled to the processing unit through a system bus; 
a hieiaitihical intennediatc representation for a heterogeneous program in the system 
memory; 

a transformation process diat is confifflired to execute e xecuting in the processing unit 
and that is oonfipured to modiiy modifying the hierarchical intermediate representation to create 
a modified intermediate representation associated with the heterogeneous program; 

a dynamic modification process that is configured to execute ^ fe oouting in the processing 
unit; and 

an application program interface that is configured to be e xecuted from the computer- 
readable medium by the processing unit, wherein the dynamic modification process is configured 
to call e afe die application program interface to cause the processing unit to modify the system 
memory associated with the heterogeneous program running in the system memory based on the 
modified intermediate representation. 

2 (currently amended): The computerized system of Claim 1 , wherein the dynamic 
modification process ^further configured to call e aib the application program interface to cause 
the processing unit to suspend processing of other programs executing in the system memory. 

3 (currently amended): The computerized system of Claim 1, wherein the dynamic 
modification process is.fijrther configured to call e afe the application program interface to cause 
the processing unit to resume processing of the other programs executing in the system memory. 

4 (currently amended): The computerized system of Claim 1, wherein modifying 
the system memory associated with die heterogeneous program causes the processing unit to 
change execution fiow of the heterogeneous program. 
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5 (currently amended): The computerized system of Claim 1, wherein the 
heterogeneo;i$ program is configured to execute oxoouting on a remote computing device with a 
remote systein memory, the dynamic modification process calls the application program 
interface to cause a remote processing unit to modify the remote system memory. 

6 (currently amended): The computerized system of Claim 5, wherein the dynamic 
modification process is fiirther configured to call fiirthor calls the application program interface 
to cause the remote processing unit to sxispend processing of other running programs running in 
the remote system memory. 

7 (currently amended); The computerized system of Claim 5, wherein the dynamic 
modification process is fijrther configured to call f urth e r caHo the application program interface 
to cause the remote processing unit to resume processing of the other programs running in the 
remote system memory. 

8 (original): An application program interface embodied on a computer-readable 
medium for execution on a computer in conjimction with a hierarchical intermediate 
representation of a heterogeneous program, the application program interface comprising: 

a navigation fimction that returns program information for a specified computing device; 
a query fimction that returns information about a program on the specified computing 

device; 

a thread ntianagement function for controlling execution of other programs on the 
specified computing device; and 

a modifier fimction for modifying the heterogeneous program residing in a system 
memory on the specified confuting device. 

9 (original): The application program interfece of Claim 8, wherein the navigation 
function includes: 

a first program fimction that returns a first program on the specified corrq)uting device. 
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10 (original): The application program interfece of Claim 8, wherein the query function 
includes a counting function that returns a number representing a count of programs executing on 
the specified computing device. 

1 1 (original): The application program interface of Claim 8, wherein the thread 
management function includes: 

a suspend fiinction that suspends other programs from executing on the specified 
computing device; and 

a resume function that resumes the execution of the other programs on the specified 
computing device. 

12 (original): The application program interfece of Claim 8, wherein the modifier 
function includes a patch function that overwrites a portion of the system memory originally 
storing part of the heterogeneous program with a new binary code for the heterogeneous 
program. 

1 3 (original): The application program interfece of Claim 8, wherein the modifier 
function includes an injector function that writes a new binary code in a portion of the system 
memory that did not originally store an original binary code for the heterogeneous pn>gFam> and 
that writes a jump instruction in a first location of the system memory that stored the original 
binary code, the new binary code being a modification to the original binary code and the jump 
instruction transferring execution to the new binary code, 

14 (original): The application program interface of Claim 8, wherein the specified 
computing device is a remote computing device. 

1 5 (original): An application program interface embodied on a computer-readable 
medium for execution on a computer, the application program interface comprising: 
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a first set of functions for creating a hierarchical internal representation of a 
heterogeneous program and for modifying the hierarchical internal representation to create a 
modified internal representation; and 

a second set of functions for dynamically modifying a system memory in which the 
heterogeneous program is executing, the system memory being modified based on the modified 
internal representation of the heterogeneous program. 

1 6 (original): The application program interface of Claim 15, wherein the second set 
further includes functions for controlling processing of other programs executing in the system 
memory, 

17 (original): The application program interface of Claim 15, wherein the second set 
fiirther includes functions for changing an execution flow of the heterogeneous program. 

18 (original): The application program interface of Claim 15, further comprising a third 
set of functions for modifying a remote system memory if the heterogeneous program is 
executing in a remote system memory on a remote computer, 

19 (original): A computer-readable medium having computer-executable instructions 
stored thereon to provide an interfece to a hierarchical intermediate representation of a 
heterogeneous program comprising: 

an instmction application interface exposed by an instruction element in the hierarchy for 
navigating, querying, modil^ng^ translating, and comtxiitting an instruction in the intermediate 
representation; 

a block application interface exposed by a block element in the hierarchy for navigating, 
querying, modifying, and committing a block in the intermediate representation; 

a procedure application interface exposed by a procedure element in the hierarchy for 
navigating, querying, modifying, and committing a procedure in the intermediate representation; 

a program application interface exposed by a program element in the hierarchy for 
modifying and querying the intermediate representation for the heterogeneous program; and 
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a system application interface exposed by a system element in the hierarchy for 
detennining the program element available on a computing device. 

20 (original): The computer-readable medium of Claim 1, further comprising a remote 
application interface for detennining the program element when the computing device is a 
remote computing device. 
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